技術問答
技術文章
iT 徵才
聊天室
2025 鐵人賽
登入/註冊
問答
文章
Tag
邦友
鐵人賽
搜尋
2023 iThome 鐵人賽
0
Modern Web
前端知識
系列 第
29
篇
10 React Antipatterns to Avoid - Code This, Not That!
15th鐵人賽
jasonchenchen
2023-10-29 16:55:49
873 瀏覽
分享至
React Anti-patterns and Solutions
Anti-pattern 1: Big Components
Problem
: Starting off with one big, deeply nested component.
Solution
: Refactor into smaller, reusable components.
Anti-pattern 2: Nesting Components
Problem
: Defining child components inside parent components.
Solution
: Define child components outside the parent component.
Anti-pattern 3: Failure to Memoize
Problem
: Running expensive calculations every time the state changes.
Solution
: Use the `useMemo` hook.
Anti-pattern 4: Useless Divs
Problem
: Wrapping multiple elements in unnecessary `div` tags.
Solution
: Use React Fragments.
Anti-pattern 5: Messy Files
Problem
: Exporting multiple components from a single file.
Solution
: One component per file.
Anti-pattern 6: Big Bundles
Problem
: Slow initial page load due to large JavaScript bundles.
Solution
: Use code splitting and lazy loading.
Anti-pattern 7: Prop Drilling
Problem
: Passing state through multiple layers of components.
Solution
: Use context API for global state management.
Anti-pattern 8: Prop Plowing
Problem
: Components with a lot of different props.
Solution
: Use the spread syntax.
Anti-pattern 9: Messy Event Handlers
Problem
: Using arrow functions for event handlers with multiple arguments.
Solution
: Use curried functions.
Anti-pattern 10: Single Object State
Problem
: Using a single object for all state in a component.
Solution
: Use multiple `useState` hooks, and extract to custom hooks
留言
追蹤
檢舉
上一篇
Better optimistic update
下一篇
ts-reset
系列文
前端知識
共
30
篇
目錄
RSS系列文
訂閱系列文
2
人訂閱
26
Learn React Hooks: useRef - Simply Explained!
27
Next.js 14.0 ( server action )
28
Better optimistic update
29
10 React Antipatterns to Avoid - Code This, Not That!
30
ts-reset
完整目錄
熱門推薦
{{ item.subject }}
{{ item.channelVendor }}
|
{{ item.webinarstarted }}
|
{{ formatDate(item.duration) }}
直播中
立即報名
尚未有邦友留言
立即登入留言
iThome鐵人賽
參賽組數
902
組
團體組數
37
組
累計文章數
19859
篇
完賽人數
528
人
看影片追技術
看更多
{{ item.subject }}
{{ item.channelVendor }}
|
{{ formatDate(item.duration) }}
直播中
熱門tag
15th鐵人賽
16th鐵人賽
13th鐵人賽
14th鐵人賽
17th鐵人賽
12th鐵人賽
11th鐵人賽
鐵人賽
2019鐵人賽
javascript
2018鐵人賽
python
2017鐵人賽
windows
php
c#
linux
windows server
css
react
熱門問題
我在做 packet tracer 的題目,想請問一下該怎麼做
dhcp 在client 端機碼設定的問題
照片破圖或是有損壞,如何修復?
Windows DHCP Server IP保留問題
新電腦安裝鼎新 Workflow ERP iGP的 Access violation
.net6 的mvc架構 如何連 report server
熱門回答
我在做 packet tracer 的題目,想請問一下該怎麼做
Windows DHCP Server IP保留問題
dhcp 在client 端機碼設定的問題
照片破圖或是有損壞,如何修復?
.net6 的mvc架構 如何連 report server
熱門文章
Agentic AI 開發實戰:我是如何設計 “Code + LLM” 混合架構,解決 AI品質不穩的問題?
【C++學習筆記】01《從零學習C++,跟世界打招呼吧!》
讓人受益終身的 9 種數據分析思維
數位轉型是什麼?從定義、三階段到成功案例一次看懂
Angular 後台系統 i18n 套件比較:Angular 內建 i18n vs ngx-translate vs ngx-atomic-i18n
IT邦幫忙
×
標記使用者
輸入對方的帳號或暱稱
Loading
找不到結果。
標記
{{ result.label }}
{{ result.account }}